package test.n00400;


import static utils.Tools.listOf;

public class Problem00481 {
    public static void main(String[] args) {
        println(new int[][]{
                {1, 2, 3}, {4, 5, 6}, {7, 8, 9}
        });
    }

    public static void println(int[][] matrix) {
        Solution ss = new Solution();
        ss.rotate(matrix);
        System.out.println(listOf(matrix) + "," + listOf(matrix));
    }

    public static class Solution {

        /**
         * 给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。
         * <p>
         * 你必须在 原地 旋转图像，这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。
         * <p>
         * 来源：力扣（LeetCode）
         * 链接：https://leetcode.cn/problems/rotate-image
         * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
         * <p>
         * 解题思路:
         * matrix[row][col] = matrix[col][n−row−1]。
         *
         * @param matrix
         */
        public void rotate(int[][] matrix) {
            int n = matrix.length;
            for (int i = 0; i < n / 2; i++) {
                for (int j = 0; j < (n + 1) / 2; j++) {
                    int temp = matrix[i][j];
                    matrix[i][j] = matrix[n - j - 1][i];
                    matrix[n - j - 1][i] = matrix[n - i - 1][n - j - 1];
                    matrix[n - i - 1][n - j - 1] = matrix[j][n - i - 1];
                    matrix[j][n - i - 1] = temp;
                }
            }
        }
    }
}
